Multidimensional Extensions (MDX) — Extensii multidimensionale 
Interogari avansate 


Laborator nr. 6 


Crearea membrilor calculaţi 


Folosirea clauzei WITH în interogările MDX: 
Se pot crea membri calculați în MDX folosind clauza WITH. Formatul general este 
următorul: 
WITH MEMBER parent .namel AS “Expression 1”, 
[MEMBER parent2.name?2 AS ‘Expression?’ , ...] 
“Parent” se referă la dimensiunea căreia îi aparţine noul membru MDX calculat, “name” 


este numele noului membru şi trebuie să fie unic. 


Interogâri care furnizează valoarea profitului 
Profitul se determină ca diferenţă între valoarea vânzărilor şi costuri, astfel, putem folosi 
următoarea interogare pentru a determina membrul calculat pentru profit folosind MDX: 


WITH MEMBER  Measures.[Store Profit] AS  “Measures.[Store Sales] -— 
Measures.] Store Cost]! 
SELECT 
1 ([Time].[ Year]. MEMBERS] ) } ON COLUMNS, 
{ ([Product].[ Product Category].MEMBERS ) } ON ROWS 
FROM Sales 
WHERE ( Measures.[Store Profit] ) 


Deci un nou membru calculat se poate folosi ca orice alt membru deja existent; un 
membru nou poate fi folosit de asemenea pentru a crea alți noi membri calculați. De exemplu, 
pentru a calcula rata profitului, folosim formula Profit/V ânzări: 


WITH 
MEMBER  Measures.[Store Profit] AS  “Measures.|[Store Sales] -— 
Measures.][ Store Cost] * 
MEMBER Measures.[Store Percent Profit] AS “Mceasures.[Store Profit] / 
Measures.] Store Cost] * 
SELECT 
1 ( Measures.| Store Profit] ) , (Measures.[Store Percent Profit] ) } ON 
COLUMNS, 
1 ([Product].[ Product Category].MEMBERS ) } ON ROWS 
FROM Sales 
WHERE ([Time].[1997]) 


O opţiune deosebit de puternică în MDX o constituie calcularea unor membri ca diferențe 
între diferite perioade de timp; de exemplu, pentru a calcula diferenţa între vânzările din 1998 şi 
cele din 1997 se poate folosi următorul model: 

WITH 

MEMBER [Time].[1998 1997 Diferenţa] AS *([Time].[1998]) — ([Time].[1997]) 


SELECT 
“([Time[.[1998 1997 Diferenţa])! ON COLUMNS, 
1(Measures.[ Unit Sales])! ON ROWS 

FROM Sales 


Pentru a afla valorile pentru vânzări, costuri şi profit pe anii 1997 şi 1998, precum şi 
diferenţele de-a lungul celor două perioade, se foloseşte următoarea interogare: 
WITH 

MEMBER Measures.| Store Profit] AS “Measures.[ Store Sales] — Measures.| Store Cost] 

MEMBER [Time].[1998 1997 Diferenta] AS “([Time].[1998]) — ([Time].[1997]) 
SELECT 

1 ( Measures.[ Store Sales]) , (Measures.| Store Cost]), (Measures.[Store Profit] ) } ON 

COLUMNS, 

1 ([Time].[1997]) , ([Time].[1998]) , ([Time].[1998 1997 Diferenta] ) ! ON ROWS 
FROM Sales 


EXPRESII 
Expresiile membru sunt de fapt funcţii care se aplică membrilor unei dimensiuni, ierarhii 
sau unui nivel şi returnează un membru, zero sau valoarea null. Expresiile sunt următoarele: 
e PREVMEMBER — returnează membrul anterior într-o ierarhie 
e NEXTMEMBER -returnează membrul următor într-o ierarhie 
e  FIRSTCHILD — returnează primul copil al unui membru în concordanță cu o ordine 
“naturală” implicită 
LASTCHILD - returnează ultimul copil al unui membru 


PARENT - returnează părintele unui membru. 


Expresiile set sunt funcţii care acționează asupra seturilor formate din mai mulți 
membri generând la rândul lor seturi. 

MEMBERS - se foloseşte pentru a obţine toţi membrii unei dimensiuni, unei ierarhii sau 
unui nivel. Pentru a obține toți membrii unei dimensiuni, expresia MEMBERS se foloseşte astfel: 

<dimension>.MEMBERS 
WITH MEMBER 

Measures.] Sales Compared to Q1] AS “([Time].CurrentMember, 

Meascures.| Store Sales])/([Time].CurrentMember.PARENT.FIRSTCHILD, 
Measures.| Store Sales] 
SELECT 

4([Measures.[ Store  Sales]) , (Measures.[ Store Cost]) , (Measures.[Store Cost]), 
(Measures.| Sales Compared to Q1] ) ! ON COLUMNS, 

{ ([Time].MEMBERS ) } ON ROWS 
FROM Sales 
WHERE  ([Product].[All producers] ,  [Customers].[All  Customers].[ USA],  [Store[.[All 
Stores].| USA], [Promotions].[ All Promotions] ) 


CHILDREN - returnează un set cu toţi copiii asociaţi cu un membru. Formatul general 
este: 
<member>.CHILDREN 
SELECT 
1(Measures.| Store Sales]) , (Measures.| Store Cost] ) } ON COLUMNS, 
4([Time].[1997].Children)! ON ROWS 
FROM Sales 
WHERE  ([Product].[All Products] ,  [Customers].[All  Customers].[ USA],  [Store[.[All 
Stores]. USA], [Promotions].[ All Promotions] ) 
Această interogare returnează vânzările pentru trimestrele Q1, Q2, Q3 şi Q4. 


DESCENDANTS -— returnează toți descendenţii unui membru particular la un anumit 
nivel în cadrul unei dimensiuni. Formatul general este: 
DESCENDANTS(<member> , <level>) 
De exemplu, următoarea interogare returnează vânzările pentru toate trimestrele din 
1998: 
SELECT 
(Measures.| Store Sales]) , ([Measures.|[ Store Cost] ) } ON COLUMNS, 
4(DESCENDANTS([Time].[1998], [Time].[Quarter] ) ! ON ROWS 
FROM Sales 
WHERE  ([Product].[All Products] , [Customers].[All  Customers].[ USA] , [Store[.[All 
Stores]. USA] , [Promotions].[ All Promotions] ) 


ORDER -— este o funcţie care permite ordonarea (ascendentă sau descendentă) 
rezultatelor unei interogări. 
SELECT 

1(Measures.| Store Sales])! ON COLUMNS, 

1ORDER([Store].|USA].[CA ].Children, Measures.[ Store Sales], DESC) } ON ROWS 
FROM Sales 
WHERE  ([Time].[1998], [Product]. [All Products],  [Customers].[All Customers], 
[Promotions].| All Promotions]) 

În interogarea precedentă, se obţine o listă a copiilor nivelului CA în ordinea 
descrescătoare a vânzărilor pentru fiecare copil. 

Pentru a obţine vânzările ordonate crescător în funcţie de statul în care au avut loc 
operaţiunile, pentru anul 1997, se foloseşte următoarea interogare: 


SELECT 

1(Measures.| Store Sales])! ON COLUMNS, 

{ORDER ([Store State]. MEMBERS , Measures.[Store Sales], ASC)! ON ROWS 
FROM Sales 
WHERE ([Time].[1997]) 


TOPSUM şi BOTTOMSUM  - sortează un set şi apoi sunt extrase primele (ultimele) 
valori a căror sumă este cel puţin egală cu valoarea specificată. 

TOPSUM(<set> , <value> , <expression>) - rezultatul interogâării este sortat după 
<expression> şi sunt extrase doar elementele a căror sumă este cel puţin <value>. De exemplu, 
următoarea interogare returnează produsele a căror vânzări sunt de cel puţin 15000. 

SELECT 

Measures.MEMBERS ON COLUMNS, 


TOPSUM([Product].] Product Category].MEMBERS, 15000, [Store Sales]) ON 
ROWS 
FROM Sales 
WHERE  ([Customers].[ All Customers],  [Store].[All Stores],  [Promotions].[All 
Promotions], [Time].[1998]) 


TOPPERCENT şi BOTTOMPERCENT - funcţionează în mod similar cu expresiile 
TOPSUM şi BOTTOMSUM. Pentru a afla care sunt produsele care deţin cel puţin 30% din 
vânzări, folosim următoarea interogare: 

SELECT 

Measures.MEMBERS ON COLUMNS, 

TOPPERCENT (|Product].[ Product Category]. MEMBERS, 30, [Store Sales]) ON 
ROWS 
FROM Sales 
WHERE ([Customers].| All Customers], [Store].[All Stores], [Promotions].[All Promotions], 
[Time].[1998]) 


Primele produse (în ordinea descrescătoare a valorii profitului net) care 
asigură obţinerea a 50% din profitul net total al firmei: 
WITH MEMBER Measures.| Profitul net] AS '[Measures].| Store Sales] — 
[Measures].[ Store Cost] 
SELECT 
{ ([Measures].[ Profitul net] ) } ON COLUMNS, 
TOPPERCENT ([Product].| Product Category]. MEMBERS, 50, [Profitul net]) 
ON ROWS 
FROM Sales 
WHERE ([Customers].[ All Customers], [Store].[ All Stores], [ Promotions].[All 
Promotions], [Time].[1997]) 


Ultimele produse (în ordinea crescătoare a valorii profitului net) care asigură 
obținerea a 50% din profitul net total al firmei: 

WITH MEMBER Measures.[Profitul net] AS '[Measures].[Store Sales] - 
[Measures].[ Store Cost] 
SELECT 

{ ([Measures].| Profitul net] ) ! ON COLUMNS, 

BOTTOMPERCENT(|Product].| Product Category]. MEMBERS, 50, [Profitul 
net]) ON ROWS 
FROM Sales 
WHERE  ([Customers].[All Customers],  [Store].[All Stores],  [Promotions].[All 
Promotions], [Time].[1997]) 


